L2 (CHAPTER 5)

Programming in Assembly
Part 1: ARM ISA
Exercises

# Question: Endianness

- Q:Assume Big Endian ordering. If a 32-bit word resides at memory address N, what is the address of:
  - (a) The MSB (Most Significant Byte)
  - (b) The 16-bit half-word corresponding to the most significant half of the word
- Q: Redo the question assuming Little Endian ordering.





# Question: Endianness



## Question: Endianness

The word stored at address 0x20008000 with Big-Endian ordering is



The word stored at address 0x20008000 with Little-Endian ordering is



| Memory<br>Address | Memory Data |
|-------------------|-------------|
| 0x20008003        | 0xA7        |
| 0x20008002        | 0x90        |
| 0x20008001        | 0x8C        |
| 0x20008000        | 0×EE        |



### Data Alignment

- Assume a byte-addressable memory with a data bus that is 32 bits (4 bytes) wide
- Consider 16 bytes of memory (addresses 0 to 15) arranged as four 32-bit words (4 bytes each)

| Address 15         | Address 14 | Address 13 | Address 12         |
|--------------------|------------|------------|--------------------|
| Address 11         | Address 10 | Address 9  | Address 8          |
| Address 7 (MSbyte) | Address 6  | Address 5  | Address 4 (LSbyte) |
| Address 3          | Address 2  | Address 1  | Address 0          |

Well-aligned: each word begins on a mod-4 address, which can be read in a single memory cycle

The first read cycle would retrieve 4 bytes from addresses 4 through 7; of these, the bytes from addresses 4 and 5 are discarded, and those from addresses 6 and 7 are moved to the far right;

The second read cycle retrieves 4 bytes from addresses 8 through 11; the bytes from addresses 10 and 11 are discarded, and those from addresses 8 and 9 are moved to the far left;

Finally, the two halves are combined to form the desired 32-bit operand:

| Address 15 | Address 14         | Address 13         | Address 12 |
|------------|--------------------|--------------------|------------|
| Address 11 | Address 10         | Address 9 (MSbyte) | Address 8  |
| Address 7  | Address 6 (LSbyte) | Address 5          | Address 4  |
| Address 3  | Address 2          | Address 1          | Address 0  |

Ill-aligned: a word begins on address 6, not a mod-4 address, which can be read in 2 memory cycles

|                    |           |        | Address 7                             | Address 6 (LSbyt             | e)                           |
|--------------------|-----------|--------|---------------------------------------|------------------------------|------------------------------|
|                    |           |        |                                       |                              |                              |
| Address 9 (MSbyte) | Address 8 |        |                                       |                              |                              |
|                    |           | •      |                                       |                              |                              |
| Address 9 (MSbyte) | Address 8 | Addres | ss 7 Addre                            | ess 6 (LSbyte)               |                              |
| _                  |           |        | · · · · · · · · · · · · · · · · · · · | Address 9 (MSbyte) Address 8 | Address 9 (MSbyte) Address 8 |

# Question: Data Alignment.

| Address 111 | Address 110 | Address 109 | Address 108 |
|-------------|-------------|-------------|-------------|
| Address 107 | Address 106 | Address 105 | Address 104 |
| Address 103 | Address 102 | Address 101 | Address 100 |
| Address 99  | Address 98  | Address 97  | Address 96  |

- Q: Assume a byte-addressable memory with a data bus that is 32 bits (4 bytes) wide. Consider 16 bytes of memory (addresses 0 to 15) arranged as four 32-bit words (4 bytes each).
  - (a) What is the address of the most significant byte of the word at address 102, , assuming Little-Endian ordering?
  - (b) What is the address of the most significant byte of the word at address 102, , assuming Little-Endian ordering?
  - (b) How many memory cycles are required to read the word at address 102?
  - (c) How many memory cycles are required to read the half word at address 102?

#### Question: Data Alignment

- Q: Assume a byte-addressable memory with a data bus that is 32 bits (4 bytes) wide. Consider 16 bytes of memory (addresses 0 to 15) arranged as four 32-bit words (4 bytes each). How many memory cycles are required to read each of the following from memory?
  - (a) A 2-Byte operand read from decimal address 5
  - (b) A 2-Byte operand read from decimal address 15
  - (c) A 4-Byte operand read from decimal address 10
  - (d) A 4-Byte operand read from decimal address 20

#### **Question: Memory Cycles**

| Address 15 | Address 14 | Address 13 | Address 12 |
|------------|------------|------------|------------|
| Address 11 | Address 10 | Address 9  | Address 8  |
| Address 7  | Address 6  | Address 5  | Address 4  |
| Address 3  | Address 2  | Address 1  | Address 0  |

- Q: Assume a byte-addressable memory with a data bus that is 32 bits (4 bytes) wide.
  - It takes \_\_\_\_ memory cycle(s) to read a Byte from memory
  - It takes \_\_\_\_ memory cycle(s) to read a half-word from memory
  - It takes \_\_\_\_ memory cycle(s) to read a word from memory
  - It takes \_\_\_\_\_ memory cycle(s) to read a double word from memory

### **Question: Arrays**

- Q: If the first element of a one-dimensional array x[] is located in memory at address 0x12345678, what will be the address of the second element if the array x[] contains
  - (a) chars
  - (b) shorts
  - (c) ints
  - (c) longs